<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  
  <title>4、hexo博客主题的修改 | haijd</title>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  
  <meta name="keywords" content="Hexo博客搭建" />
  
  
  
  
  <meta name="description" content="Hexo博客搭建">
<meta name="keywords" content="Hexo博客搭建">
<meta property="og:type" content="article">
<meta property="og:title" content="4、Hexo博客主题的修改">
<meta property="og:url" content="http://www.hais2.com/2016/03/06/Hexo-Getting-Started-4/index.html">
<meta property="og:site_name" content="haijd">
<meta property="og:description" content="Hexo博客搭建">
<meta property="og:locale" content="default">
<meta property="og:image" content="http://ww3.sinaimg.cn/mw690/c55a7aeejw1f1njlex0x6j208508hgli.jpg">
<meta property="og:image" content="http://ww3.sinaimg.cn/mw690/c55a7aeejw1f1nkrahlcrj212n0m1qc9.jpg">
<meta property="og:image" content="http://ww1.sinaimg.cn/mw690/c55a7aeejw1f1nl81t9bvj212n0j4jvv.jpg">
<meta property="og:image" content="http://ww1.sinaimg.cn/mw690/c55a7aeejw1f1nlprob22j21290l70tl.jpg">
<meta property="og:updated_time" content="2017-08-02T15:22:33.000Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="4、Hexo博客主题的修改">
<meta name="twitter:description" content="Hexo博客搭建">
<meta name="twitter:image" content="http://ww3.sinaimg.cn/mw690/c55a7aeejw1f1njlex0x6j208508hgli.jpg">
  
    <link rel="alternate" href="/atom.xml" title="haijd" type="application/atom+xml">
  
  <link rel="icon" href="/css/images/favicon.ico">
  
    <link href="//fonts.googleapis.com/css?family=Source+Code+Pro" rel="stylesheet" type="text/css">
  
  <link href="https://fonts.googleapis.com/css?family=Open+Sans|Montserrat:700" rel="stylesheet" type="text/css">
  <link href="https://fonts.googleapis.com/css?family=Roboto:400,300,300italic,400italic" rel="stylesheet" type="text/css">
  <link href="//cdn.bootcss.com/font-awesome/4.6.3/css/font-awesome.min.css" rel="stylesheet">
  <style type="text/css">
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/9749f0/00000000000000000001008f/27/l?subset_id=2&fvd=n5) format("woff2");font-weight:500;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/90cf9f/000000000000000000010091/27/l?subset_id=2&fvd=n7) format("woff2");font-weight:500;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/8a5494/000000000000000000013365/27/l?subset_id=2&fvd=n4) format("woff2");font-weight:lighter;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/d337d8/000000000000000000010095/27/l?subset_id=2&fvd=i4) format("woff2");font-weight:400;font-style:italic;}</style>
    
  <link rel="stylesheet" id="athemes-headings-fonts-css" href="//fonts.googleapis.com/css?family=Yanone+Kaffeesatz%3A200%2C300%2C400%2C700&amp;ver=4.6.1" type="text/css" media="all">
  <link rel="stylesheet" href="/css/style.css">

  <script src="/js/jquery-3.1.1.min.js"></script>

  <!-- Bootstrap core CSS -->
  <link rel="stylesheet" href="/css/bootstrap.css" >
  <link rel="stylesheet" href="/css/hiero.css" >
  <link rel="stylesheet" href="/css/glyphs.css" >
  
    <link rel="stylesheet" href="/css/vdonate.css" >
  

</head>

<script>
var themeMenus = {};

  themeMenus["/"] = "Home"; 

  themeMenus["/archives"] = "Archives"; 

  themeMenus["/categories"] = "Categories"; 

  themeMenus["/tags"] = "Tags"; 

  themeMenus["/about"] = "About"; 

</script>


  <body data-spy="scroll" data-target="#toc" data-offset="50">


  <header id="allheader" class="site-header" role="banner">
  <div class="clearfix container">
      <div class="site-branding">

          <h1 class="site-title">
            
              <a href="/" title="haijd" rel="home"> haijd </a>
            
          </h1>

          
            <div class="site-description">Stay Hungry,Stay Foolish</div>
          
            
          <nav id="main-navigation" class="main-navigation" role="navigation">
            <a class="nav-open">Menu</a>
            <a class="nav-close">Close</a>
            <div class="clearfix sf-menu">

              <ul id="main-nav" class="nmenu sf-js-enabled">
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/">Home</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/archives">Archives</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/categories">Categories</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/tags">Tags</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/about">About</a> </li>
                    
              </ul>
            </div>
          </nav>


      </div>
  </div>
</header>




  <div id="container">
    <div id="wrap">
            
      <div id="content" class="outer">
        
          <section id="main" style="float:none;"><article id="post-Hexo-Getting-Started-4" style="width: 66%; float:left;" class="article article-type-post" itemscope itemprop="blogPost" >
  <div id="articleInner" class="clearfix post-1016 post type-post status-publish format-standard has-post-thumbnail hentry category-template-2 category-uncategorized tag-codex tag-edge-case tag-featured-image tag-image tag-template">
    
    
      <header class="article-header">
        
  
    <h1 class="thumb" class="article-title" itemprop="name">
      4、Hexo博客主题的修改
    </h1>
  

      </header>
    
    <div class="article-meta">
      
	Posted on <a href="/2016/03/06/Hexo-Getting-Started-4/" class="article-date">
	  <time datetime="2016-03-06T14:54:10.000Z" itemprop="datePublished">March 6, 2016</time>
	</a>

      
	<span id="busuanzi_container_page_pv">
	  本文总阅读量<span id="busuanzi_value_page_pv"></span>次
	</span>

    </div>
    <div class="article-entry" itemprop="articleBody">
      
        <p>　　在这一篇中介绍一下Hexo主题的一些修改方法，在这里是基于默认主题介绍的，但是了解一下，对使用其他主题也有些帮助。</p>
<h2 id="主题文件说明"><a href="#主题文件说明" class="headerlink" title="主题文件说明"></a>主题文件说明</h2><p>　　依次打开博客文件夹根目录下的<code>themes\landscape\</code>，可以看见主题包里面一些文件夹和文件，我们先认识一下这些文件分别是什么：<br><img src="http://ww3.sinaimg.cn/mw690/c55a7aeejw1f1njlex0x6j208508hgli.jpg" alt=""><br>　　1. <code>languages</code>：语言文件包，存放网页语言文件。<br>　　2. <code>layout</code>：页面模板文件夹，保存生成静态页面的HTML模板文件，使用的是EJS模板引擎编写，会HTML的话就很容易看懂。<br>　　3. <code>scripts</code>：存放网页中要使用的脚本文件。<a id="more"></a><br>　　4. <code>source</code>：存放资源文件，比如CSS文件和js文件、图片等静态资源。<br>　　5. <code>.gitignore</code>：git提交时的忽略文件配置信息文件，主题自动生成的，不用管。<br>　　6. <code>_config.yml</code>：主题的配置文件。<br>　　7. <code>Gruntfile.js</code>：这个是前端的代码压缩文件，使用Grunt工具压缩代码，减少页面加载时间。这个是新增的文件，其他主题中可能没有，不用在意。<br>　　8. <code>LICENSE</code>：Git生成的版权许可文件，不用管。<br>　　9. <code>package.json</code>：前端工具包配置文件，配置前端工具等信息，比如刚才的Grunt工具的信息就是在这里配置的。不用管。<br>　　10. <code>README.md</code>：github生成的项目说明文件。不用管。</p>
<h2 id="主题修改"><a href="#主题修改" class="headerlink" title="主题修改"></a>主题修改</h2><p>　　了解了主题中的文件之后，其实修改主题的话，主要用到的有三个：<code>_config.yml</code>、<code>layout</code>、<code>source</code>。其中<code>_config.yml</code>为配置文件不用太多的修改，上一篇中介绍过了。Hexo主题的主要修改的文件就在后两个文件夹中。<br>　　“layout”文件中主要是网页的HTML模板代码，“source”文件夹中是网页的样式文件(css)和一些动态效果的文件(js)。对前端比较熟悉的同学可以研究一下，自己编写想要的风格和效果，由于我的前端知识不多，就不详细介绍了。</p>
<h3 id="source文件夹"><a href="#source文件夹" class="headerlink" title="source文件夹"></a>source文件夹</h3><p>　　由于样式文件夹中的内容比较简单一些，我们先来看看：<br>　　打开之后又三个文件夹：<code>css</code>、<code>fancybox</code>、<code>js</code>。其中<code>fancybox</code>是fancybox插件用到的一些静态文件，不用管它。其他两个就是样式和脚本了。<br>　　这两个文件夹中的内容可以根据需要随意修改，举个例子，我们打开<code>css</code>文件夹，可以看到有一个<code>images</code>文件夹，这里面就是CSS用到的背景图片之类的资源，把里面的图片替换掉看看效果：<br><img src="http://ww3.sinaimg.cn/mw690/c55a7aeejw1f1nkrahlcrj212n0m1qc9.jpg" alt=""></p>
<h3 id="layout文件夹"><a href="#layout文件夹" class="headerlink" title="layout文件夹"></a>layout文件夹</h3><p>　　这个文件夹算是比较重要的，博客页面构成就靠它了。<br>　　点进去看看能够知道，landscape主题的文件分布比较细致，基本每一个模块都分离成单独的文件了，这样容易看懂，修改也比较方便，赞一个。<br>　　具体的代码就不介绍了，大家感兴趣可以看看，很简单的，尝试修改然后预览，这样大致就明白里面的代码了。在这里只介绍一下给文章添加一个多说评论、侧边栏增加一个微博秀。</p>
<h4 id="添加多说评论"><a href="#添加多说评论" class="headerlink" title="添加多说评论"></a>添加多说评论</h4><p><strong>申请多说评论账号</strong><br>　　大家可以去<a href="http://duoshuo.com/" target="_blank" rel="noopener">多说网站</a>申请一个多说账号，具体的申请就不多介绍了，介绍一下怎么用：<br>　　进入你添加的博客站点后台，找到工具这一栏，可以看到有获取代码的选项，我们使用通用代码就可以了，复制生成的代码：<br><img src="http://ww1.sinaimg.cn/mw690/c55a7aeejw1f1nl81t9bvj212n0j4jvv.jpg" alt=""><br>　　<br><strong>粘贴代码</strong><br>　　依次打开<code>\layout\_partial\article.ejs</code>，找到文件中的<code>&lt;footer class=&quot;article-footer&quot;&gt;</code>节点，在该节点的前面粘贴刚刚复制的代码。<br>　　1. 将<code>data-thread-key</code>的值替换成<code>&lt;%= page.path %&gt;&quot;</code>。<br>　　2. 将<code>data-title</code>的值替换成<code>&lt;%= page.title %&gt;</code>。<br>　　3. 将<code>data-url</code>的值替换成<code>&lt;%= page.permalink %&gt;</code>。</p>
<p>　　现在保存该文件，刷新一下页面试试，看看评论框是不是出现在了合适的位置：<br><img src="http://ww1.sinaimg.cn/mw690/c55a7aeejw1f1nlprob22j21290l70tl.jpg" alt=""></p>
<p>　　<strong>大家可以按照这样的方式，举一反三，给博客添加百度分享等插件。</strong></p>
<h4 id="添加微博秀侧边栏组件"><a href="#添加微博秀侧边栏组件" class="headerlink" title="添加微博秀侧边栏组件"></a>添加微博秀侧边栏组件</h4><p>　　大家可以去微博主页，搜索微博秀就可以看到微博秀的网页应用了，然后就可以获得微博秀的插件代码，具体的获取方式就不多做介绍了 。</p>
<p><strong>增加微博秀侧边栏模板</strong><br>　　依次打开<code>\layout\_widget</code>，新建一个名为”weiboshow.ejs”的文件，用编辑器打开，添加下面的代码并保存：<br><figure class="highlight applescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line">&lt;<span class="keyword">div</span> <span class="built_in">class</span>=<span class="string">"widget-wrap"</span>&gt;</span><br><span class="line">    &lt;h3 <span class="built_in">class</span>=<span class="string">"widget-title"</span>&gt;微博秀&lt;/h3&gt;</span><br><span class="line">    &lt;<span class="keyword">div</span> <span class="built_in">class</span>=<span class="string">"widget"</span>&gt;</span><br><span class="line">      </span><br><span class="line">      在这里粘贴你的微博秀插件代码</span><br><span class="line">      </span><br><span class="line">    &lt;/<span class="keyword">div</span>&gt;</span><br><span class="line">  &lt;/<span class="keyword">div</span>&gt;</span><br></pre></td></tr></table></figure></p>
<p><strong>在主题配置中添加微博秀组件</strong><br>　　我们已将创建好了微博秀的模板，现在需要把组件添加到主题的配置文件中，让Hexo渲染出来。</p>
<p>　　打开主题文件夹根目录下的<code>_config.yml</code>文件，找到<code>widgets</code>这个配置节点，在下面添加微博秀模板的名字“weiboshow”比如：<br><figure class="highlight haml"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br></pre></td><td class="code"><pre><span class="line">...</span><br><span class="line"></span><br><span class="line"># Sidebar</span><br><span class="line">sidebar: right   #侧边栏的位置</span><br><span class="line">widgets:        #侧边栏小工具组件</span><br><span class="line">-<span class="ruby"> weiboshow     <span class="comment">#微博秀组件     </span></span></span><br><span class="line"><span class="ruby">- category      <span class="comment">#分类</span></span></span><br><span class="line"><span class="ruby">- tag           <span class="comment">#标签</span></span></span><br><span class="line"><span class="ruby">- tagcloud      <span class="comment">#标签云</span></span></span><br><span class="line"><span class="ruby">- archive       <span class="comment">#存档</span></span></span><br><span class="line"><span class="ruby">- recent_posts  <span class="comment">#最新发布</span></span></span><br><span class="line"><span class="ruby"></span></span><br><span class="line"><span class="ruby">...</span></span><br></pre></td></tr></table></figure></p>
<p>　　从这里不难看出，Hexo主题会从配置文件中读取侧边栏挂件信息，去对应的寻找文件进行加载。  值得注意的是，这些名称的顺序会影响挂件在页面的显示顺序，比如我把”weiboshow”写在第一行了，那么在加载页面是，我的微博秀就是侧边栏的最上面。<br><img src="" alt=""></p>

      
    </div>
    <footer class="entry-meta entry-footer">
      
	<span class="ico-folder"></span>
    <a class="article-category-link" href="/categories/Hexo/">Hexo</a>

      
  <span class="ico-tags"></span>
  <ul class="article-tag-list"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tags/Hexo博客搭建/">Hexo博客搭建</a></li></ul>

      
        <div id="donation_div"></div>

<script src="/js/vdonate.js"></script>
<script>
var a = new Donate({
  title: '如果觉得我的文章对您有用，请随意打赏。您的支持将鼓励我继续创作!', // 可选参数，打赏标题
  btnText: 'Donate', // 可选参数，打赏按钮文字
  el: document.getElementById('donation_div'),
  wechatImage: '/css/images/wechatPay.png',
  alipayImage: '/css/images/alipay.jpg'
});
</script>
      

      
        
	<section id="comments" class="comment">
	  <div id="disqus_thread">
	  <noscript>Please enable JavaScript to view the <a href="//disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
	  </div>
	</section>

	<script type="text/javascript">
	var disqus_shortname = 'haijdblog';
	(function(){
	  var dsq = document.createElement('script');
	  dsq.type = 'text/javascript';
	  dsq.async = true;
	  dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
	  (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
	}());
	(function(){
	  var dsq = document.createElement('script');
	  dsq.type = 'text/javascript';
	  dsq.async = true;
	  dsq.src = '//' + disqus_shortname + '.disqus.com/count.js';
	  (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
	}());
	</script>


      
    </footer>
  </div>
  
    
<nav id="article-nav">
  
    <a href="/2016/03/07/Hexo-Getting-Started-6/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption">Newer</strong>
      <div class="article-nav-title">
        
          5、Hexo博客的写作
        
      </div>
    </a>
  
  
    <a href="/2016/03/05/Hexo-Getting-Started-3/" id="article-nav-older" class="article-nav-link-wrap">
      <strong class="article-nav-caption">Older</strong>
      <div class="article-nav-title">3、Hexo博客配置和主题</div>
    </a>
  
</nav>

  
</article>

<!-- Table of Contents -->

  <aside id="sidebar">
    <div id="toc" class="toc-article">
    <strong class="toc-title">Contents</strong>
    
      <ol class="nav"><li class="nav-item nav-level-2"><a class="nav-link" href="#主题文件说明"><span class="nav-number">1.</span> <span class="nav-text">主题文件说明</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#主题修改"><span class="nav-number">2.</span> <span class="nav-text">主题修改</span></a><ol class="nav-child"><li class="nav-item nav-level-3"><a class="nav-link" href="#source文件夹"><span class="nav-number">2.1.</span> <span class="nav-text">source文件夹</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#layout文件夹"><span class="nav-number">2.2.</span> <span class="nav-text">layout文件夹</span></a><ol class="nav-child"><li class="nav-item nav-level-4"><a class="nav-link" href="#添加多说评论"><span class="nav-number">2.2.1.</span> <span class="nav-text">添加多说评论</span></a></li><li class="nav-item nav-level-4"><a class="nav-link" href="#添加微博秀侧边栏组件"><span class="nav-number">2.2.2.</span> <span class="nav-text">添加微博秀侧边栏组件</span></a></li></ol></li></ol></li></ol>
    
    </div>
  </aside>
</section>
        
      </div>
      <footer id="footer" class="site-footer">
  

  <div class="clearfix container">
      <div class="site-info">
	      &copy; 2018 haijd All Rights Reserved.
          
            <span id="busuanzi_container_site_uv">
              本站访客数<span id="busuanzi_value_site_uv"></span>人次  
              本站总访问量<span id="busuanzi_value_site_pv"></span>次
            </span>
          
      </div>
      <div class="site-credit">
        Theme by <a href="https://github.com/iTimeTraveler/hexo-theme-hiero" target="_blank">hiero</a>
      </div>
  </div>
</footer>


<!-- min height -->

<script>
    var contentdiv = document.getElementById("content");

    contentdiv.style.minHeight = document.body.offsetHeight - document.getElementById("allheader").offsetHeight - document.getElementById("footer").offsetHeight + "px";
</script>
    </div>
    <!-- <nav id="mobile-nav">
  
    <a href="/" class="mobile-nav-link">Home</a>
  
    <a href="/archives" class="mobile-nav-link">Archives</a>
  
    <a href="/categories" class="mobile-nav-link">Categories</a>
  
    <a href="/tags" class="mobile-nav-link">Tags</a>
  
    <a href="/about" class="mobile-nav-link">About</a>
  
</nav> -->
    

<!-- mathjax config similar to math.stackexchange -->

<script type="text/x-mathjax-config">
  MathJax.Hub.Config({
    tex2jax: {
      inlineMath: [ ['$','$'], ["\\(","\\)"] ],
      processEscapes: true
    }
  });
</script>

<script type="text/x-mathjax-config">
    MathJax.Hub.Config({
      tex2jax: {
        skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']
      }
    });
</script>

<script type="text/x-mathjax-config">
    MathJax.Hub.Queue(function() {
        var all = MathJax.Hub.getAllJax(), i;
        for(i=0; i < all.length; i += 1) {
            all[i].SourceElement().parentNode.className += ' has-jax';
        }
    });
</script>

<script type="text/javascript" src="https://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML">
</script>


  <link rel="stylesheet" href="/fancybox/jquery.fancybox.css">
  <script src="/fancybox/jquery.fancybox.pack.js"></script>


<script src="/js/scripts.js"></script>
<script src="/js/bootstrap.js"></script>
<script src="/js/main.js"></script>








	<script async src="//dn-lbstatics.qbox.me/busuanzi/2.3/busuanzi.pure.mini.js">
	</script>






  </div>

  <a id="rocket" href="#top" class=""></a>
  <script type="text/javascript" src="/js/totop.js" async=""></script>
</body>
</html>
